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Resume 

Ce document reprend mes notes personnelles, sur un style "informel", prises au cours de la conference 
ECMDA 2007. II mentionne l'integralite du programme de la conference (titre de 1' article et nom de la 
personne qui a presente) en detaillant certaines des presentations. 
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1 Introduction 



La conference europeenne ECMDA-FA'07 (htt pT? /www . haif a . il . ibm. com/ c on f erences/ecmda2 07 / 1 
sur ringenierie Dirigee par les Modeles a eu lieu le 13 et 14 juin 2007 a Haifa (Israel). Cette conference 
est decoupee en 2 types de session : Applications (plutot industrielles) et Foundations (plutot acade- 
miques). Les actes sont edites par Springer dans le LNCS Vol. 4530. Le programme de la conference est 
accessible al'adresse |http : / / www . haif a . il . ibm . com/ co nferences/ ecmda2 00 7 /program . html 

et le resume de chacune des presentations a l'adresse |http : / /www . haif a . il . ibm. com/conf erences/ec mda2 7 /abstract 

Adosse a cette conference ont eu lieu le 1 1 juin un workshop informel sur la rencontre entre acade- 
miques et industriels et le 12 juin un workshop sur la tracabilite des modeles ( h ttp : //m odelbas ed . net /ecmda-traceability/) 
dont les actes sont disponibles a l'adresse |http : / /modelbased ■ net /ecmda-traceability/papers07/ECMDA-TW-07-Prc 

2 ECMDA : Main Conference (June 13, 2007) 

2.1 Keynote : Stuart Kent (Microsoft) 

Pragmatics of Model Driven development 

Apres avoir presente les notions de DSL et de DSD (Domain-Specific Development) tels qu'ils sont 
definis chez Microsoft, Stuart Kent a presente le pragmatique de la plateforme Visual Studio pour le 
developpement specifique a un domaine. A travers un exemple d' application (reservation de chambres 
d'hotel), il a presente la plate-forme selon les points suivants : 

- Validation de contraintes : utilisation du langage LINQ, un langage proche d'OCL avec des primi- 
tives pour la generation de messages d'erreurs. 

- Modeles complexes : possibilites de combiner differents diagrammes (de meme type ou pas) cor- 
respondants a differents points de vue ou a differents niveaux de hierarchisation. La plate-forme 
supporte le referencement de fragments de modele a partir d'operateurs comme diff., merge 

- Mappings (generation de code, reverse, model to model) : le but est de pouvoir travailler sur des 
parties generees. On definit pour cela sur le code ou le modele les parties qui sont maitres (lec- 
ture/ecriture) et celles qui sont esclaves (lecture uniquement). Une limite toutefois : le probleme 
du round-tripping. 

- Personnalisation : la personnalisation peut se faire sur les generateurs d'outils, sur les generateurs 
de code ou sur le code genere. Le versionning devient alors complique : Tool platform vendor (vl, 
v2...), tool vendor (vl.l, vl.2...v2.1....), tool customizers (vl.1.1, 1.1.2....) et application builder 
(vl. 1.1.1....). Cela pose alors le probleme de qui peut personnaliser quoi ? La plate-forme doit 
permettre de le definir clairement. 

- Integration du processus : la plate-forme essaye de combiner l'approche DSL avec les methodes 
agiles. 

2.2 Session A : Applications 

Model Transformation from OWL-S to BPEL Via SiTra (Gareth Howells, Kent Univer- 
sity) 

L expose a porte principalement sur la presentation du langage de transformation SiTra (Simple 
Transformer) ; l'application OWL2BPEL detaillee dans l'article n'etant que brievement evoquee. 
Les hypotheses de conception de ce langage de transformation sont : 

- les utilisateurs ne veulent pas utiliser une nouvelle approche autre que celle des langages de pro- 
grammation, 

- ils ne veulent pas apprehender de nouveaux concepts de programmation. 

Ainsi, SiTra a pour objectif de permettre d'ecrire une transformation par un langage de program- 
mation (java. . . ) et fournit pour cela des librairies : la classe SimpleTransformer, les interfaces Rule et 
Transformer, et un certain nombre de methodes (check pour verifier si la transformation peut etre appli- 
quee, build pour construire un element du modele cible, setProperties pour assigner des valeurs a des 
proprietes du modele cible. . . ) a specialiser pour chaque transformation. 

L execution de la transformation revient alors a creer une instance de Transformer, a enregistrer la 
transformation, puis a appeler chacune des regies quand la methode check renvoie true (ie. l'objet n'a 
pas encore ete traite). 
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Les fonctionnalites principales de la version actuelle sont la definition de regies simples, la reutilisa- 
tion de regies (composition ET/OU), 1' heritage de regies et l'invocation implicite/explicite de regies. 

Les limitations actuelles de la plate-forme sont l'invocation recursive d'une regie et le choix de la 
regie a appliquer pour un meme objet. 

Towards a Model-Driven Approach to automatic BPEL (Xiaofeng Yu, Nanjing Univer- 
sity par tele-conference) 

Presentation d'un mapping en QVT entre EDOC-CCA (profil UML de l'OMG pour EDOC qui per- 
met de modeliser la structure et le comportement de composants et leurs orchestrations) et BPEL (langage 
de workflows executable). Le but est d'utiliser EDOC-CCA pour specifier de maniere abstraite l'orches- 
tration puis generer automatiquement le workflow BPEL. 

A Model-Driven Software Factory using DSL (presente par Anneke Kleppe, Twente Uni- 
versity) 

L' expose a commence par une introduction au framework Microsoft : Les developpeurs de DSL 
definissent un domain model a partir duquel ont peut generer un composant qui s'installe dans TIDE pour 
le developpement d' applications. Les developpeurs d'applications definissent des application model, 
conformes au modele de domaine et genere ensuite semi-automatiquement le code de leur application. 

Le reste de la presentation etait un retour d'experience sur l'utilisation de ce framework pour le 
developpement de l'usine logicielle SMART-Microsoft. Les conclusions principales sont : 

- d'utiliser des petits DSL et accepter qu'ils ne prennent pas tout en compte, 

- un modele ne doit pas tenir compte d'une technologie particuliere. C'est la transformation Mo- 
del2Code qui doit introduire cette technologie. 

2.3 Session B : Foundations 

A Practical Approach to Model Extension (Jean Bezivin, INRIA) 

L' expose a commence par une presentation de la plate-forme AMMA (ATM, AMW, AM3. . . ) puis 
a montre la necessite d'avoir des mecanismes d'extension de modele (+ notion de treillis de modeles). 
L'exemple pris pour cela est le meta-modele des reseaux de Petri que Ton souhaite etendre pour ajouter 
le marquage courant au cours d'une execution. 

Les auteurs proposent une formalisation de la relation "extensionOf" (un sous ensemble clair de 
l'operateur "merge" introduit par l'OMG) et propose trois moyens de l'implementer : concatenation de 
descriptions textuelles en KM3, un modele de lien (weaving) entre les 2 parties du meta-modele ou une 
approche par transformation de modele qui complete le premier par les informations du second. 

Towards the Generation of a Text Based IDE from a language Metamodel (Anneke 
Kleppe, Twente University) 

Apres avoir introduit les principales differences entre un meta-modele et une grammaire (references 
conteneurs, mots-cles absent du metamodele. . . ), l'auteur propose une approche pour definir des outils 
textuels (base sur une BNF) a partir d'un meta-modele. 

Elle definit la notion de Parse Model (PM) qui rajoute au modele de la syntaxe abtraite (ASM), a 
travers une transformation ASM2PM, les mots-cles permettant le parsing de texte (Rq : il peut y avoir 
plusieurs PM pour un ASM). A partir de la, une transformation PM2BNF fait le pont vers les outils 
generatifs de l'ingenierie des langages. Les principales conclusions sont : 

- des outils textuels peuvent etre generes a partir d'un meta-modele, 

- il faut une separation claire entre la syntaxe abstraite et une ou plusieurs syntaxes concretes. 

Human Comprehensible and Machine Processable Specifications of Operational Seman- 
tics (Markus Scheidgen, Berlin University) 

Les auteurs presentent dans cet article une methode pour decrire la semantique operafionnelle d'un 
meta-modele. lis proposent de definir pour une classe statique (instance de la metaclasse contenant les 
informations statiques), n classes d'execution, toutes instances de la metaclasse heritant de la premiere 
et rajoutant les informations dynamiques, i.e. evoluant au cours de l'execution. lis proposent ensuite de 
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definir des diagrammes d'activites pour definir les transitions possibles d'un etat a l'autre d'un modele. 
L'operationalisation est exprimee a l'aide d' actions de base de creation, modification, suppression. . . 

Associe a cette approche, ils ont definis un interpreteur generique permettant 1' execution de modeles 
definis a partir d'un meta-modele complete d'une telle description de la semantique. 

2.4 Session C : Applications 

Improving the Interoperability of Automative Tools by Raising the Abstraction from Le- 
gacy XMI Formats to Standardized Meta-Models (Mark Brokens, Carmeq GmbH) 

Model Re-engineering from Traces to Validate Distributed Systems - An Industrial Case 
Study (Andreas Ulrich, Siemens AG) 

Adopting Model-Driven Development in a Large Financial Organization (Yael Shaham- 
Gafni, Metaphor Vision Ltd.) 

3 ECMDA : Main Conference (June 14, 2007) 

3.1 Keynote : Andy Schiirr (Darmstadt University of Technology) 

Model-Driven Development With Matlab Simulink & Stateflow 

L' expose a montre l'utilisation de l'atelier Matlab Simulink & Stateflow (MSS) dans les projets Mate 
et Toolnet. 

Le projet MATE (htt pT? /www .mof Ion . org/success_stories/mate ■ html ) avait pour 
objectif de definir des guidelines sous MSS et les verifier sur les modeles definis. Le principe adopte est de 
passer par le MOF et la definition de SDM (diagramme d'activite UML + regies de re-ecriture de graphes) 
a l'aide de transformations definis avec l'environnement MOFLON ( |http : / /www .mof Ion . org/) . 
Les apports par rapport a OCL sont d' avoir des proprietes plus simples a lire, de pouvoir les definir de 
maniere graphique et avec un plus fort pouvoir d'expression (fermeture transitive ...). 

Le projet TOOLNET (http : / / www . mof Ion . org/ success_stories /toolnet . html) per- 
met d'etablir des liens de tracabilite entre des exigences et les modeles MSS. Ils definissent pour cela des 
specifications bi-directionnelles (en utilisant le langage de transformation de graphe TGG, sous ensemble 
de QVT) et generent tous les differents scenarios. 

L expose se termine par une description de l'atelier MOFLON (MOF, DiaGen, OCL, SDM, TGG, 
Velocity) et une comparaison par rapports aux autres (AMMA, GME, Fujaba. . . ). 

Les problemes ouverts : 

- certains concepts UML (associations qualifiees. . . ), 

- integrer la definition de profil UML, 

- contraintes OCL : verification de contraintes incrementales, fermeture transitive, pattern-matching. . . 

- definition formelle des transformations de modeles locales avec SDM, 

- fusionner TGG avec QVT relationnel, 

- l'integration avec le framework de generation d'editeur Diameta (http : / / www .mof Ion . org/success_stories/diameta 

3.2 Session D : ModelWare 

Is MDA Ready for Real Business ? - A User Perspectives ! (Bjorn Nordmoen, Western- 
Geco) 

Conclusions en vrac : 

- on peut pas e valuer 1' amelioration de la productivite, 

- la creation de profils est trop compliquee. 
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Adopting MDA in a Small Enterprise (Regis Vogel, IHG) 

Experimental Validation of the Effects of Model Driven Development on the Software 
Lifecycle (Yael Dubinsky, IBM Haifa Research Lab) 

Modelware Discussion 

3.3 Session E : Foundations 

Scenarios of Traceability in Model to Text Transformations (Goran Olsen, SINTEF) 

Presentation de l'outil MOFscript implementant le langage de transformation de meme nom. II a ete 
developpe sous la forme d'un plugin Eclipse, dans le cadre de Modelware. 

La presentation souligne la necessite d'avoir des liens de tracabilite dans le cadre de transformations 
modele a texte (tracabilite end-to-end, specifications des transformations differentes du developpement 
de systeme par les ingenieurs, modifications manuelles du code genere. . . ). Dans MOFscript : 

- la transformation a des references vers les elements du modele, 

- chaque reference est utilisee pour generer un fichier texte. 

De cette maniere, le prototype permet d'avoir une vision de la trace pour chaque element du modele, une 
couverture des elements utilises pour generer. . . 

An Algebraic view on the Semantics of Model Composition 

Formalisation de la composition de modeles a differents niveaux (syntaxique, semantique, mefho- 
dique) et etudes de differentes proprietes a chacun des niveaux. 

Execution of Aspect oriented UML Models (Pablo Sanchez, University of Malaga) 

Hypothese de depart : les modeles executables sont une realite mais pas encore de module de concep- 
tion d' applications base sur le "cross-cutting" : 

=>■ expression du comportement par des diagrammes d'activites, 
=>■ transformation en Xpath et ATL pour gerer le cross cutting. 

3.4 Session F : Foundations 

Templateable Metamodel for Semantic Variation Points (Arnaud Cucurru, CEA LIST) 

Les auteurs s'interessent aux points de variation semantique (PVS) dans les metamodeles. Ces PVS 
consistuent une information essentielle dans le domaine de l'ingenierie des langages mais sont aussi 
presents dans 1'IDM ou ils ne sont pas clairement identifies et sont decrits le plus souvent informellement 
dans la documentation associee aux metamodeles. La specification d'UML 2 est un bon exemple de cet 
etat de fait. Ainsi, le MOF ne propose aucun mecanisme pour identifier ni traitor les PVS. 

Les auteurs proposent de s'inspirer du mecanisme de genericite present dans les langages de pro- 
grammation pour parametrer un metamodele, aussi bien au niveau des paquetages que des meta-classes. 
La notation proposee s'appuie sur les templates d'UML 2 et est illustree sur les machines a etats d'UML 
2 en s'interessant a deux points de variation semantique : la selection des evenements et la selection 
des transitions. Chacun de ces deux PVS est decrit par une meta-classe, est utilise comme parametre 
de genericite du paquetage des machines a etat et de la meta-classe State concernee par ces PVS. Deux 
realisations concretes de ces PVS sont proposees correspondant a des politiques respectivement aleatoire 
et stochastique. 

Constraints Modeling for (Profiled) UML Models (Francois Lagarde, CEA LIST) 

L' expose part du constat qu'un stereotype ajoute une information semantique a un element du mo- 
dele. L' augmentation du nombre de profils definis amene a ce poser des questions sur leurs comptabilites 
entre eux, i.e. definition d'un cadre sain pour appliquer plusieurs profils simultanement. Dans ce contexte, 
les auteurs proposent des mecanismes pour exprimer des contraintes portant sur 1' application. Ces meca- 
nismes ont ete definis par des profils. 

Quelques informations ont ete donnees sur le prototype (plugin Eclipse) qui est en train d'etre deve- 
loppe et les algorithmes utilises pour evaluer les regies sur les modeles. 
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Efficient Reasoning About Finite Satisfiability of UML Class Diagrams with Constrained 
Generalization Sets (Azzam Maraee, Ben-Gurion University of Israel) 

4 Conclusion 

La prochaine edition de cette conference ce tiendra du 9 au 12 juin 2008 a Berlin. La date limite de 
soumission des articles est d'ores et deja fixee au 5 fevrier 2008. 
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